home *** CD-ROM | disk | FTP | other *** search
/ Workbench Add-On / Workbench Add-On - Volume 1.iso / Dev / Oberon / source / amiga / MathTrans.mod < prev    next >
Text File  |  1995-06-29  |  3KB  |  118 lines

  1. (**************************************************************************
  2.  
  3.      $RCSfile: MathTrans.mod $
  4.   Description: Interface to mathtrans.library
  5.  
  6.    Created by: fjc (Frank Copeland)
  7.     $Revision: 3.8 $
  8.       $Author: fjc $
  9.         $Date: 1995/06/04 23:13:14 $
  10.  
  11.   $VER: mathtrans_protos.h 1.2 (7.11.90)
  12.   Includes Release 40.15
  13.  
  14.   (C) Copyright 1985-1993 Commodore-Amiga, Inc.
  15.       All Rights Reserved
  16.  
  17.   Oberon-A interface Copyright © 1994-1995, Frank Copeland.
  18.   This file is part of the Oberon-A Interface.
  19.   See Oberon-A.doc for conditions of use and distribution.
  20.  
  21. ***************************************************************************)
  22.  
  23. <* STANDARD- *>
  24.  
  25. MODULE [2] MathTrans;
  26.  
  27. IMPORT SYS := SYSTEM, Kernel, e := Exec;
  28.  
  29.  
  30. (*-- Library Base variable --------------------------------------------*)
  31.  
  32. CONST
  33.  
  34.   MathTransName * = "mathtrans.library";
  35.  
  36. VAR
  37.  
  38.   base *  : e.LibraryPtr;
  39.  
  40.  
  41. (*-- Library Functions ------------------------------------------------*)
  42.  
  43.  
  44. PROCEDURE Atan* [base,-30]
  45.   ( parm [0] : REAL )
  46.   : REAL;
  47. PROCEDURE Sin* [base,-36]
  48.   ( parm [0] : REAL )
  49.   : REAL;
  50. PROCEDURE Cos* [base,-42]
  51.   ( parm [0] : REAL )
  52.   : REAL;
  53. PROCEDURE Tan* [base,-48]
  54.   ( parm [0] : REAL )
  55.   : REAL;
  56. PROCEDURE Sincos* [base,-54]
  57.   ( VAR cosResult [1] : REAL;
  58.     parm          [0] : REAL )
  59.   : REAL;
  60. PROCEDURE Sinh* [base,-60]
  61.   ( parm [0] : REAL )
  62.   : REAL;
  63. PROCEDURE Cosh* [base,-66]
  64.   ( parm [0] : REAL )
  65.   : REAL;
  66. PROCEDURE Tanh* [base,-72]
  67.   ( parm [0] : REAL )
  68.   : REAL;
  69. PROCEDURE Exp* [base,-78]
  70.   ( parm [0] : REAL )
  71.   : REAL;
  72. PROCEDURE Log* [base,-84]
  73.   ( parm [0] : REAL )
  74.   : REAL;
  75. PROCEDURE Pow* [base,-90]
  76.   ( power [1] : REAL;
  77.     parm  [0] : REAL )
  78.   : REAL;
  79. PROCEDURE Sqrt* [base,-96]
  80.   ( parm [0] : REAL )
  81.   : REAL;
  82. PROCEDURE Tieee* [base,-102]
  83.   ( parm [0] : REAL )
  84.   : e.SINGLE;
  85. PROCEDURE Fieee* [base,-108]
  86.   ( parm [0] : e.SINGLE )
  87.   : REAL;
  88.  
  89. (* --- functions in V31 or higher (distributed as Release 1.1) ---*)
  90.  
  91. PROCEDURE Asin* [base,-114]
  92.   ( parm [0] : REAL )
  93.   : REAL;
  94. PROCEDURE Acos* [base,-120]
  95.   ( parm [0] : REAL )
  96.   : REAL;
  97. PROCEDURE Log10* [base,-126]
  98.   ( parm [0] : REAL )
  99.   : REAL;
  100.  
  101.  
  102. (*-- Library Base variable --------------------------------------------*)
  103.  
  104. <*$LongVars-*>
  105.  
  106. (*-----------------------------------*)
  107. PROCEDURE* [0] CloseLib (VAR rc : LONGINT);
  108.  
  109. BEGIN (* CloseLib *)
  110.   IF base # NIL THEN e.CloseLibrary (base) END;
  111. END CloseLib;
  112.  
  113. BEGIN
  114.   base := e.OpenLibrary (MathTransName, e.libraryMinimum);
  115.   IF base = NIL THEN HALT (100) END;
  116.   Kernel.SetCleanup (CloseLib)
  117. END MathTrans.
  118.